草庐IT

python - 按多列分组以查找重复行 Pandas

全部标签

ruby-on-rails - 删除 staging.rb 和 production.rb 之间的重复

我的Rails应用程序(在Heroku上运行)有一个暂存和生产环境。目前,我必须在每个文件中分别定义staging.rb和production.rb中的很多内容,例如:#Codeisnotreloadedbetweenrequestsconfig.cache_classes=true#Fullerrorreportsaredisabledandcachingisturnedonconfig.consider_all_requests_local=falseconfig.action_controller.perform_caching=true#DisableRails'sstatic

ruby-on-rails - 查找数组元素

我有一个数组@words=Word.find_all_by_lesson_id(params[:id])-@user.words并且想通过word_id找到一个元素,比如@current_word=@words[params[:id2].to_i]在哪里params[:id2]是words.id当然错了,因为数组索引和words.id不一样,那我该怎么做才能正确呢?或如果我想从模型中排除一些记录,你能建议我如何使用该模型吗? 最佳答案 @current_word=@words.detect{|w|w.id==params[:id2]

ruby-on-rails - 按 ruby​​ 中的值对哈希进行分组

我有一个ruby哈希,看起来像这样:{"admin_milestones"=>"1","users_milestones"=>"0","admin_goals"=>"1","users_goals"=>"0","admin_tasks"=>"1","users_tasks"=>"0","admin_messages"=>"1","users_messages"=>"0","admin_meetings"=>"1","users_meetings"=>"0"}我正在寻找一种解决方案,可以将这个散列分成两部分,一个值为1,另一个散列值为0。 最佳答案

ruby-on-rails - 查找两个条件都为真的所有记录

我正在尝试查找满足两个条件的所有记录。例如:ruby-1.8.7-p302>Person.all=>#=>#=>#我想获取“Jane”和“Tom”的记录。我正在尝试这个,但它不起作用:Person.find_all_by_state("Wisconsin").find_all_by_single(true) 最佳答案 Person.where(:state=>"威斯康星州",:single=>true) 关于ruby-on-rails-查找两个条件都为真的所有记录,我们在StackOve

ruby-on-rails - 在 Ruby on Rails 中查找未使用的 View /部分

我目前正在从事一个大型的RubyonRails项目。它已经足够老,也足够大,以至于不清楚是否所有View都在实际使用中。有没有可以生成未使用View文件列表的脚本/插件? 最佳答案 我写了一个脚本来查找未使用的部分/View。不过,我假设“未使用”意味着存在一个View文件,但没有为其定义Controller方法(不再)。该脚本不检查View是否被调用,因为没有从默认路由到它的链接。这会复杂得多。将以下脚本放在应用程序的脚本文件夹中:#!/usr/bin/envrubyrequire'config/environment'(Dir[

ruby - Python itertools 的 Ruby 等价物是什么,尤其是。组合/排列/groupby?

Python的itertools模块提供了很多关于使用生成器处理可迭代/迭代器的好东西。例如,permutations(range(3))-->012021102120201210combinations('ABCD',2)-->ABACADBCBDCD[list(g)fork,gingroupby('AAAABBBCCD')]-->AAAABBBCCDRuby中有哪些等价物?等效的,我的意思是快速和内存高效(Python的itertools模块是用C编写的)。 最佳答案 Array#permutation、Array#combin

ruby - 从 Ruby 数组中删除顺序重复项

假设我有以下数组,我想去掉连续的重复项:arr=[1,1,1,4,4,4,3,3,3,3,5,5,5,1,1,1]我想得到以下信息:=>[1,4,3,5,1]如果有比我的解决方案(或其变体)更简单、更高效的东西,那就太好了:(arr+[nil]).each_cons(2).collect{|i|i[0]!=i[1]?i[0]:nil}.compact或(arr+[nil]).each_cons(2).each_with_object([]){|i,memo|memo编辑:看起来@ArupRakshit下面的解决方案非常简单。我仍在寻找比我的解决方案更高效的方法。编辑:我将在响应出现时对

ruby-on-rails - 查找关联记录存在的位置

我如何才能只选择那些具有关联标签记录的员工?换句话说,只选择具有一个或多个与之相关联的标签记录的员工记录。classEmployee下面的查询(这是错误的)会让你们了解我正在尝试做什么。Employee.includes(:tags).where("tags.id!=nil") 最佳答案 您可以使用.joinsEmployee.joins(:tags)此生成的SQL包含tags表上的INNERJOIN,省略没有关联tagsemployees表记录记录。 关于ruby-on-rails-查

ruby 通过重复字符或空格拆分字符串

我如何分割这个字符串。"68855588866887777"=>["6","88","555","8","88","66","88","7777"]我试过了,但是没用。ruby-1.8.7-p334:020>"111133".split(/(\d)\1+/)=>["","1","","3"] 最佳答案 split将只使用它匹配的任何内容作为分隔符,并将其从相关字符串中删除。您要找的是scan:str="68855588866887777"str.scan(/((\d)\2*)/).map(&:first)#=>["6","88","

ruby - 在 ruby​​ 中哪个更快 - 散列查找或带有 case 语句的函数?

在时间紧迫的脚本中,我们有几个地方可以将旧ID转换为字符串。目前,我们在函数内部使用case语句,如下所示:defget_nameidcaseidwhen1"onething"when3"otherthing"else"defaultthing"endend我正在考虑将其替换为哈希查找,如下所示:NAMES={1=>"onething",3=>"otherthing",}NAMES.default="defaultthing"感觉使用NAMES[id]应该比使用get_name(id)更快-但真的是这样吗? 最佳答案 首先,有几点。